<template>
	<view class="wrap">
		<view class="top"></view>
		<view class="content">
			<view class="title">欢迎登录长院淘淘</view>
			<input class="u-border-bottom" v-model="username" placeholder="请输入用户名" />
			<input class="u-border-bottom" type="password" v-model="password" placeholder="请输入密码" />
			<button @tap="submit" :style="[inputStyle]" class="getCaptcha">登录</button>
			<view class="alternative">
				<view class="password" @click="$u.route('pages/login/register')">注册</view>
				<view class="issue">遇到问题</view>
			</view>
			<u-toast ref="uToast" />
		</view>

	</view>
</template>

<script>
	export default {
		name:'login',
		data() {
			return {
				username: '',
				password: ''
			}
		},

		computed: {
			inputStyle() {
				let style = {};
				if (this.$u.test.enOrNum(this.username) && this.$u.test.enOrNum(this.username)) {
					style.color = "#fff";
					style.backgroundColor = this.$u.color['warning'];
				}
				return style;
			}
		},
		methods: {
			async submit() {
				if (!this.$u.test.enOrNum(this.username) || !this.$u.test.enOrNum(this.username)) return
				const params = {
					username: this.username,
					pwd: this.password
				}
				try {
					const {
						data
					} = await this.$u.api.userLogin(params)
					if (!data) return
					switch (data.code) {
						case '10001':
							this.$u.toast(data.msg)
							break;
						case '10004':
							this.$u.toast(data.msg)
							break;
						case '10005':
							this.$u.toast(data.msg)
							break;
						case '10006':
							this.$u.toast(data.msg)
							break;
						default:
							const res = await this.$u.api.getUserInfo()
							this.$u.vuex('vuex_token', data.result.token)
							this.$u.vuex('vuex_user', res.data.result)
							this.$u.toast(data.msg)
							//登陆成功之后跳转到来源页
							setTimeout(() => {
								const backurl = uni.getStorageSync('back_url') || 'pages/index/index'
								this.$u.route({
									type: 'reLaunch',
									url: backurl
								})
							}, 1000)

					}
				} catch (e) {
					console.log(e)
				}

			}
		}
	};
</script>

<style lang="scss" scoped>
	.u-border-bottom {
		margin-bottom: 30rpx !important;
	}

	.wrap {
		font-size: 28rpx;

		.content {
			width: 600rpx;
			margin: 80rpx auto 0;

			.title {
				text-align: left;
				font-size: 60rpx;
				font-weight: 500;
				margin-bottom: 100rpx;
			}

			input {
				text-align: left;
				margin-bottom: 10rpx;
				padding-bottom: 6rpx;
			}

			.tips {
				color: $u-type-info;
				margin-bottom: 60rpx;
				margin-top: 8rpx;
			}

			.getCaptcha {
				background-color: rgb(253, 243, 208);
				color: $u-tips-color;
				border: none;
				font-size: 30rpx;
				padding: 12rpx 0;

				&::after {
					border: none;
				}
			}

			.alternative {
				color: $u-tips-color;
				display: flex;
				justify-content: space-between;
				margin-top: 30rpx;
			}
		}

		.buttom {
			.loginType {
				display: flex;
				padding: 350rpx 150rpx 150rpx 150rpx;
				justify-content: space-between;

				.item {
					display: flex;
					flex-direction: column;
					align-items: center;
					color: $u-content-color;
					font-size: 28rpx;
				}
			}

			.hint {
				padding: 20rpx 40rpx;
				font-size: 20rpx;
				color: $u-tips-color;

				.link {
					color: $u-type-warning;
				}
			}
		}
	}
</style>
